## Lab 02: Understanding uvm\_sequence\_item

Objective: To Learn how to create and use uvm\_sequence\_item with uvm\_field\_\* macros in UVM.

## Step 1:

- Create a new file named **mem\_seq\_item.sv**.
- Extend the class from uvm sequence item.
- Add the following fields:

```
a. rand bit [3:0] addr;
b. rand bit wr_en;
c. rand bit rd_en;
d. rand bit [7:0] wdata;
e. bit [7:0] rdata;
```

- Register the class using uvm\_object\_utils\_begin() and uvm\_object\_utils\_end().
- Use the following uvm field \* macros:
  - a. UVM ALL ON for addr
  - b. UVM NOPRINT for wr en (prevents printing)
  - c. UVM DEFAULT for rd en (default behavior)
  - d. UVM\_COPY | UVM\_COMPARE for wdata (used in copy & compare but not print)
- Implement a constructor (new()).
- Add a constraint ensuring wr\_en and rd\_en are not both 1 at the same time.

## Step 2:

- Create a new file named **seq\_item\_tb.sv**.
- Declare two instances of mem seq item: seq item1 and seq item2.
- Inside an initial block:
  - a. Create and randomize seq item1.
  - b. Print the values of seq\_item1 using print().
  - c. Copy seq item1 into seq item2 using copy().
  - d. Print the values of seq item2 using print().
  - e. Modify addr in seq item2.
  - f. Compare seq item1 and seq item2 using compare().
  - g. Display whether they match or differ.
- Run and observe the output.